

# Finite State Machine (FSM) Design Techniques in Verilog HDL

Video Lecture Link1

Video Lecture Link2

Video Lecture Link3



- □ What is FSM?
- ☐ Moore and Mealy FSM Block Diagram
- ☐ FSM Design Techniques
- ☐ Verilog HDL Design
- ☐ Synthesizing the Design
- ☐ Test Bench Design
- ☐ Analysing Simulation Waveforms



In Digital VLSI design, Finite State Machines play a very important role in implementing the correct behaviour of the system during different operating modes.

The FSM enables the system to go through different operating modes as per the user requirements or during the self booting process

#### **Moore and Mealy FSM**

# Inputs Next State Logic Present State Logic Output Logic Output State Logic

Figure #01: Moore Finite State Machine Block Diagram

#### **Moore and Mealy FSM**

#### **Melay Machine**



Figure #02: Melay Finite State Machine Block Diagram



Different Techniques to Design Finite State Machines are as below –

- 1) Using a Single Process (Procedural Block) to Code Present State, Next State and Output Logic
- 2) Using Two Process, One to code Present State and Next State logic and another to code Output Logic,
- 3) Using Three Process each to code Present State, Next State and Output Logic



Verilog HDL Design and Test-Bench Simulation:

We will be using **EDA Playground (https://www.edaplayground.com)** to design Fixed Priority Round Robin Arbiter in Verilog HDL.

Synthesis using Open Source Synthesis Tool: Yosys (Available in EDA Playgound)

Simulation using Open Source Simulation Tool: Riviera (Available in EDA Playground)

Verilog Project Link1

Verilog Project Link2

Verilog Project Link3



If you find the content valuable, Please do not forget to hit the **b**utton

Also, please do subscribe my YouTube channel and enable the notification to get notified for next such designs.

I would appreciate your suggestions, any queries and any digital design you would like to understand starting from circuit to HDL design. Please write them down in the comment section !!!

Thank You!!!